-
Notifications
You must be signed in to change notification settings - Fork 716
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add a dockerized version #424
base: master
Are you sure you want to change the base?
Conversation
I don't understand the motivation for this. The |
Motivation
I’ve never thought about this, my only motivation was naively running into a persistent container. Now that you mention it, I took a time for thinking and here you go some: Portability: Lets say my persistent continer is running remotely and I would like to get the same todotxt environment all over my devices/oses: macos laptop, windows desktop, ubuntu raspberri pi, etc. With the plus of no dependency hell (which is also one of my developer’s life purposes). Ease of Deployment: Back in the days I created my own script for this: ssh into my remote host, and sync with my local todo.txt folder. The problem with that was that every other device had to sync with the remote host. What if instead of syncing I maintian a single source of truth that could be loaded no matter my device? Scalability: This is something Ive also never thought but what if I would like to distribute my todotxt-s with my team? I could continue but I believe its clear my main motivation was containerization per se which, by the way, its something nobody asked as a feature before.
You might be right, but that’s something solved with docker volumes.
You’re right, I don’t. The point is not running I’m a lazy developer that hates to install the same software over multiple devices/oses. Even a tiny app like todo.txt might behave differently depending on the system it’s running on. Foremost motivation I dont want to re-(install/configure) it every time I reinstall any of my devices/oses (and believe me it happens often). Another why not: What if I want that incredibly useful piece of software as part of a larger ecosystem or devops platform for automation. Final thoughtsLet’s say you work with a remote team, and everyone uses todo.txt for managing their personal tasks. Rather than requiring everyone to configure their environment or ensure they have the correct dependencies, you could share a Docker image that contains todo.txt along with any relevant configuration and remote file system for the data. Team members just need to run Even tho I may agree with you that while todo.txt is small, containerization brings a host of advantages like portability, ease of sharing, isolation, and integration with larger systems and workflows. The overhead is minimal, and for many users or teams, the trade-off for these benefits is worth it—especially when compared to the simplicity of setting up and managing a containerized environment. I might understand it’s a software that wasn’t thought for this purpose but at the end of the day who decides what’s the best use for a software: Their users. In the past I’ve considered to contribute with this project. Now I believe I have another motivation for doing so. With all that said, let me add some tests to that Dockerfile. Thank you for your really good questions. |
With your detailed explanation, it makes a bit more sense ;-) For synchronization or sharing tasks among the team, the usual approach is a Dropbox / Google Drive / Nextcloud etc. folder as But your main point is the portability and ease of installation. My first thoughts on that go towards solutions like Snap or Flatpak, which offer app stores and single-click installations. Of course, these also use containerization under the hood, and Docker can provide the encapsulation, too. Going with Docker, I think users would expect to simply Before going further, it would be good to first have more feedback from the community; i.e. whether there's demand for Docker (or rather Snap / Flatpak / whatever). |
Before submitting a pull request, please make sure the following is done:
master
.fixes #XX
reference to the issue that this pull request fixes.